import { constRoutes, asyncRoutes } from '@/router'
export default {
  namespaced: true,
  state() {
    return {
      routes: constRoutes
    }
  },
  mutations: {
    setRoutes(state, newRoutes) {
      state.routes = [...constRoutes, ...newRoutes]
    }
  },
  actions: {
    // 筛选权限路由
  // 第二个参数为当前用户的所拥有的菜单权限
  // menus: ["settings","permissions"]
  // asyncRoutes是所有的动态路由
  // asyncRoutes  [{path: 'setting',name: 'setting'},{}]
    filterRoutes(context, menus) {
      const routes = []
      //   筛选出 动态路由中和menus中能够对上的路由
      menus.forEach(key => {
      // key就是标识
      // asyncRoutes 找 有没有对象中的name属性等于 key的 如果找不到就没权限 如果找到了 要筛选出来
        routes.push(...asyncRoutes.filter(item => item.name === key)) // 得到一个数组 有可能 有元素 也有可能是空数组// 【 ☆☆☆ 一定要确保路由里面的name字段是否和数据库返回的标识是否统一，检查一致，否则出现丢失】
      })
      // 得到的routes是所有模块中满足权限要求的路由数组
      // routes就是当前用户所拥有的 动态路由的权限
      context.commit('setRoutes', routes) // 将动态路由提交给mutations
      console.log(routes,'过滤好的权限---------');
      return routes // 这里为什么还要return  state数据 是用来 显示左侧菜单用的  return  是给路由addRoutes用的
    }
  }
}
